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£2 ( 57 ) Abstract: Mobile code, such as an applet, is permitted to create a network connection with a content server on a network, with- 
— out restricting the applet only to connections from the computer from which it was downloaded. This is achieved in accordance with 
2 *e principles of the present invention by using network restriction software in the execution engine or runtime system under which 
the applet executes. When the applet attempts to create a network connection to a content server, the network restriction software 
Q checks a name field on the content server for the presence of an entry whose name corresponds to the name of the computer from 
J> which the applet was downloaded. If such an entry is present, then the network restriction software permits the network connection 
^ between the applet and the content server to be created. If not, the applet may not create a network connection with the content server. 
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SYSTEM AND METHOD FOR SPECIFYING ACCESS 
TO RESOURCES IN A MOBILE CODE SYSTEM 

BACKGROUND OF THE INVENTION 

5 The growth of the Internet has led to the development of numerous 

technologies for the distribution of content over the World Wide Web. Among these 
technologies are systems that permit Web content to include executable code, that is 
sent from a Web server to a Web client, where it is executed. Such "mobile code" or 
"applets" allow content providers to distribute content that includes programmed 

10 behavior, which may be used in a variety of ways. Mobile code systems, such as 
Java, produced by Sun Microsystems, of Palo Alto, California, or Curl, provided by 
Curl Corporation, of Cambridge, Massachusetts, may greatly enhance the experience 
of Web users by providing a relatively efficient way for highly interactive or media- 
rich content to be sent across the Web. 

1 5 Although such mobile code systems provide access to highly desirable 

features, they also raise serious security issues. Including executable code in Web 
content exposes Web users to a variety of attacks. The same systems that provide an 
efficient way to distribute highly interactive or engaging content also provide a 
means to distribute malicious code, such as viruses, programs designed to steal 

20 information from user's computers, or other damaging programs. Even if such 
programs are not intentionally distributed, the use of mobile code opens the 
possibility that errors in executable Web content may have potentially disastrous 
results on the computers of Web users who view the content. These security issues 
are made worse by the fact that the highly interactive Web applications that can be 

25 designed using mobile code are particularly attractive to Web users, who may be 
easily induced to view Web pages containing hostile mobile code. 

To address these security issues, mobile code systems such as Java typically 
impose limits on which system resources may be accessed by applets. An applet 
will typically have only limited access to the file system on a client computer, the 
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CPU, memory, the network resources available to the computer, and so on; 
Additionally, the programming languages associated with mobile code systems 
typically include features which enhance security, such as type safety and garbage 
collection, to prevent inappropriate use of operations on objects, unsafe access to 
5 memory resources, memory leakage, and other potential memory-related problems 
that may be exploited by malicious code. 

Unfortunately, despite these efforts, it is difficult or impossible to create a 
useful programming language or mobile code system that is completely free of 
security issues. A clever attacker can exploit minor security holes to effectively 
10 completely break the security of a mobile code system, and launch a variety of 
attacks. 

Attempts have been made to reduce the possibility of attacks by limiting the 
locations on a network that may be accessed by an "unprivileged" (or "untrusted") 
applet. For example, some mobile code systems permit an unprivileged applet to 
15 use a network only to access resources on the server from which the applet was 
downloaded. While this effectively limits the ability of such untrusted applets to 
attack computers other than the server that provided the applet and the client 
computer that downloaded the applet, in can be a severely limiting restriction. 

SUMMARY OF THE INVENTION 

20 The severely limiting restriction of permitting an unprivileged applet to only 

establish a network connection to the server from which the applet was downloaded 
is overcome by the use of a name file on a content server. The present invention 
allows an applet to make a connection to any server which will allow it access. 

A method of creating a network connection between an applet executing on a 

25 client computer and a content server computer determines a home site name for the 
applet, the home site name corresponding to a host name of a computer from which 
the applet was downloaded to the client computer. A name file on the content server 
computer is checked for the presence of a hostname entry having an access 
construct, the hostname entry corresponding to the home site name for the applet. 

30 The applet is permitted to create a network connection with the content server 
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computer if the hostname entry was present. The applet is denied permission to 
create a network connection with the content server computer if the hostname entry 
was not present. Execution of applets on the client computer is controlled by an 
execution engine. Checking for the presence of a hostname entry in the name file of 

5 the content server computer comprises using network restriction software in the 
execution engine to check for the presence of the hostname entry. 

Access constructs in the name file comprise an allow list, the allow list 
includes the hostname entry representing a computer from which the applet is 
allowed to have been download from in order to allow the creation of the network 

10 connection. The access constructs can also comprise an except list, which includes 
the hostname entry representing a computer from which the applet is not allowed to 
have been downloaded from in order to allow the creation of the network 
connection. The host name entries in either the allow construct or the except 
construct can be specified using wildcards. A special entry (allow-all) can be 

1 5 included in the name file to allow access to applets downloaded from any host 
computer. 

The hostname entry can be used to determine types of network connections 
that are permitted between the applet and the content server computer as well as to 
perform an address check. The address check determines an address list for the 
20 content server computer, determines an address list for the computer from which the 
applet was downloaded and denies permission for the applet to create a network 
connection with the content server computer if the address list for the content server 
computer is not a subset of the address list for the computer from which the applet 
was downloaded. 

25 The address check can also deny permission for the applet to create a network 

connection with the content server computer if the home site name for the applet is 
in dotted quad form, and an address specified by the dotted quad form is not 
identical to an address for the content server computer. 
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BREF DESCRIPTION OF THE DRAWINGS 

The various features and advantages of the invention will be apparent from 
the following description of particular embodiments of the invention, as illustrated 
in the accompanying drawings in which like reference characters refer to the same 
5 parts throughout the different views. The drawings are not necessarily to scale, 
emphasis instead being placed upon illustrating the principles of the invention. 

FIG. 1 is a diagram of a content server in accordance; 

FIGS. 2A - 2B are illustrative diagrams of a name file; 

FIG. 3 is a diagram of a name file using Allow and Except constructs in 
1 0 accordance with the principles of the present invention; 

FIG. 4 is a diagram of a name file using an Allow- All construct in 
accordance with the principles of the present invention; 

FIG. 5 is a diagram showing use of an execution engine and network 
restriction software in accordance with a preferred embodiment of the present 
15 invention; 

FIG. 6 is a flowchart of a preferred embodiment of the network restriction 
software of the present invention; 

FIG. 7 is a diagram of a network environment suitable for use with the 
system and methods of the present invention; and 
20 FIG. 8 is a diagram of a computer system suitable for use with the system 

and methods of the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

Referring to FIG. 1, Web server 10, having a host name of 
4 Ww.example.com", provides access to a variety of Web content 12, such as Web 
25 pages and applets. Web server 10 may also provide services that may be accessed by 
applets or mobile code running on client computers. Access to such services may be 
granted through use of name file 14, in accordance with the methods and apparatus 
described in commonly owned, co-pending U.S. Patent Application 09/818,302, 
filed oaMarch 27, 2001, and entitled "System and Methods for Securely Permitting 
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Mobile Code to Access Resources Over a Network", which is incorporated herein by 
reference. 

Name file 14 is a file on Web server 10, that can be accessed over a network. 
Whenever an applet wishes to establish a connection with Web server 10, the 

5 execution engine or runtime system in which the applet executes first checks to see 
if the name of the computer from which the applet was loaded is matched in name 
file 14 on Web server 10. If so, then the connection can be established. If not, then 
the applet is not permitted to establish a connection with Web server 10. 

Referring now to FIG. 2A, a more detailed view of name file 14 is shown. 

1 0 Name file l4 may contain zero or more entries, each entry indicating a name of an 
alternative host name for the computer on which the name file is located, or 
otherwise specifying the host name of a computer whose applets are permitted to 
create connections with the computer on which the name file is located (hereinafter, 
the "content server"). Such entries in a name file, such as name file 14, shall be 

1 5 referred to hereinafter as c< hostname entries". 

In FIG. 2A, name file 14 contains hostname entry 20a, having the name 
<< www.example.com". Thus, applets from www.example.com are permitted to 
establish connections to www.example.com, because its name file contains 
hostname entry 20a. In addition to hostname entry 20a, name file 14 also contains 

20 hostname files 20b and 20c, which represent standard synonyms for 

"www.example.com" which would typically be used within the "example.com" 
domain. 

In FIG. 2B, a name file 14 contains hostname entries 22a - 22£ each 
specifying a different host name. It is possible that multiple host names may all refer 

25 to the same computer, or that all of the named computers may serve content for the 
same logical web site. By placing multiple hostname entries in name file 14, applets 
originating from any of the named computers of hostname entries 22a - 22f are 
permitted to access the computer on which name file 14 is located. Thus, an applet 
having a home site of "www.example.com" or 'Svww3.example.com" could access 

30 the content server on which name file 14 is located, but an applet having a home site 
of '*badname.example.com" could not. 
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A name file, such as name file 14, should he present on each computer with 
which an applet should be able to create a network connection, hi the case of 
computers that "mirror" each other to create multiple sources for a logical web site, 
each such computer should have in its name file an entry for the name of the logical 
5 web site. The name files of such "mirror*' computers may also have other entries, 
such as entries for their own host names. 

It will be understood by one skilled in the relevant arts that name file 14 
could be implemented using a variety of constructs, such as a name directory, or a 
name database, or by other means of storing such data in a manner that permits it to 
10 be accessed over a network. It will further be recognized by one skilled in the arts 
that the hostname entries contained in name file 14 need not contain only host 
names. Other information, such as the types of network connections that are 
permitted with the content server could be specified with the host names in name file 
14. 

15 Referring now to FIG. 3, name file 30, prepared in accordance with the 

principles of the present invention, contains Allow construct 32 and Exclude 
construct 36. Allow construct 32 is followed by host names of the home sites of 
applets that are allowed to access the system on which name file 30 is present 
(hereinafter referred to as the "allow list")- The host names following Allow 

20 construct 32 may optionally include wildcards, such as is shown in host name 34b, 
to indicate that applets from numerous host names should be allowed access. The 
«*» wildcard character can be used to match any string of zero or more characters. 
For example, host name 34b specifies that applets from "*. example.com" should be 
allowed to access the content server. This means that applets from any host name, 

25 followed by ".example.com", such as "www.example.com" 4 Vww2.example.com", 
"test.example.com", or any other system in the "example.com" domain, should be 
allowed to access the content server on which name file 30 is present 

The "?" wildcard character may be used to match any single character. Thus, 
host name 34c, which specifies that applets from 'Ww7.example.net" should be 

30 allowed access, would allow access to applets from "wwwl .example.net", 

"www2.example.net", 'SvwwA.example.net", and so on. Host name 34c would not 
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permit access to applets from 'Hestexample.net" or 'Vww29.example.net", since 
these do not match '^Kn^.examplejiet". 

It will be understood by one skilled in the relevant arts that other wildcard 
characters may be used in the host names that follow Allow construct 32. In general 

5 the host names following Allow construct 32 may comprise any regular expression. 
It should be noted that in a preferred embodiment, the wildcard characters may not 
appear in a domain name. Thus, com" and "www.* com" would not be valid 
entries in the allow list, since the wildcard character appears in the domain name, 
rather than in the host name. 

10 Advantageously, permitting use of wildcard characters in the allow list 

permits rapid specification of numerous home systems for applets that are permitted 
to access a content server. Use of wildcard characters provides greatly increased 
flexibility in describing a network of related systems. 

Except construct 36 is also followed by a list of host names 38a - 38b 

1 5 (hereinafter, the "except list"). The host names following Except construct 36 

represent the systems whose applets are not permitted to access the system on which 
name file 30 is located, despite the possibility that, due to use of wildcard characters, 
they may match one or more of the names listed in the allow list following Allow 
construct 32. Thus, applets from host name 38a C'notallowed.example.com") would 

20 not be able to access the content server on which name file 30 is located, even 
though host name 34b in the allow list specifies that "*.example.com" should be 
allowed access. 

Note that if a name appears on, or is matched on both the allow list and the 
except list, the entry in the except list takes precedence, and applets from the host 
25 named in the except list will not be permitted access to the content server. This 
policy prevents ambiguity when a host name appears on both the allow list and the 
except list. 

Unlike the host names following Allow construct 32, in a preferred 
embodiment, wildcard characters may not be used to specify host names following 
30 Except construct 36. This further clarifies the policy that the except list takes 

precedence over the allow list, since each host name on the except list must be fully 
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specified. Advantageously, the ability to use wildcards in an Allow construct, but 
not in an Except construct provides a high degree of control over access, while being 
easy to understand and easy to use. 

Referring to FIG. 4, in accordance with the principles of the present 

5 invention, Allow-All construct 40 is shown in name file 42. Allow-All construct 40 
may be used to allow applets from any applet server to access the content server on 
which name file 42 is located. 

It should be noted that name files as described hereinabove can be used at the 
"roof level of a web site or other resource that is accessible over a network, or at 

10 any other point in a directory structure associated with such a site. If used in a 
directory, the name file controls access to the resources contained in that directory. 
Where a name file is used at the root level of the site, it controls access to everything 
on the site, and overrides any name files found in directories. 

Use of Allow, Except, and Allow- All constructs in name files on a content 

1 5 server allows the content server to specify which applet servers will be able to 
provide applets that may access the content server. Enforcement of the restrictions 
specified by these constructs is handled on the client computer that executes an 
applet. Thus, as shown in FIG. 5, client computer 50 runs applet 52 by using an 
execution engine 54. Running an applet within an execution engine, such as 

20 execution engine 54, is typical for mobile code systems, and typically permits 
applets to be machine independent, so they may be executed on different types of 
computers or operating systems, as long as any computer on which the applet is to be 
used is capable of running the execution engine in which the applet is executed. 
Use of an execution engine also permits mobile code, such as applet 52, to 

25 have its ability to access resources on client computer 50 limited. For example, 
because applet 52 is executed by execution engine 54, execution engine 54 may 
restrict applet 52 from accessing files on client computer 50. Similarly execution 
engine 54 may restrict the ability of applet 52 to establish network connections with 
other computers. 

30 In accordance with the principles of the present invention, execution engine 

54 includes network restriction software 56, which is the only software through 
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which applets executed by execution engine 54 are able to establish network 
connections with other computers. Network restriction software 56 permits applet 
52 to connect with other computers only after first checking that a name file on the 
computer with which a connection is to be established contains an Allow-All 

5 construct, or that the name file contains an Allow construct followed by an entry that 
matches the name of the home site of applet 52, and that the home site of applet 52 , 
is not on the list of names that follows an Except construct Only if these conditions 
are met will network restriction software 56 permit a connection to be established. 
It will be understood that the system and methods of the present invention are 

1 0 complimentary to, and may be used in conjunction with the methods described in the 
U.S. Patent application entitled "System and Methods for Securely Permitting 
Mobile Code to Access Resources Over a Network", which was incorporated by 
reference hereinabove. In a preferred embodiment, network restriction software 56 
restricts access in accordance with the methods described therein, as well as 

1 5 performing the functions described with reference to FIGS. 5 and 6. 

Referring now to FIG. 6, a flowchart showing the operation of a preferred 
embodiment of network restriction software 56 is described. At step 101, a request 
to create a network connection is received from an applet. Preferably, all attempts 
by applets to create connections to other computers over a network are processed 

20 through the network restriction software of the execution engine under which the 
applets execute. 

At step 102, the network restriction software retrieves a name file from the 
content server to which the applet is attempting to connect. Preferably, the file is 
checked to make certain that it is a valid name file, that it is consistent, and adheres 

25 to the necessary syntax rules. 

At step 103, the network restriction software checks to see if the 
name file contains an Allow-All construct. If so, then access is permitted. 
Otherwise, at step 104, the network restriction software checks to see if the home 
system of the applet is in the except list following an Except construct. 

30 If the home system of the applet is not in an exclude list, at step 1 05, the 

network restriction software checks to see of the home system of the applet matches 
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an entry in the allow list following an allow construct. If so, then access is 
permitted. Otherwise, if the home system of the applet does not match an entry in 
the allow list, or the home system of the applet is listed in the except list, then access 
is not permitted, 

5 At step 106, if access is permitted, the network restriction software allows 

the applet to establish a connection with the content server. 

At step 107, if access was not permitted, network restriction software 56 does 
not allow the applet to create a network connection and access the resource that it 
requested from the content server. In a preferred embodiment, network restriction 

10 software 56 provides the applet with only limited information about the failure to 
establish a connection. Specifically, the applet is not given information on the 
reason that access was denied, since such information could be used to for hostile 
purposes, such as network mapping. Note that a user of the client may be given 
more information about the reason for a failure (e.g., in an error message on his 

1 5 screen) than should be provided to the applet that attempted to access the resource. 

It will be understood by one skilled in the relevant arts that the procedures 
provided hereinabove may be implemented in a variety of ways. It will further be 
recognized that various optimizations may be used to reorder or skip the listed steps 
without changing the semantics of the procedures. 

20 Note that Allow and Except constructs in accordance with the present 

invention are preferably used on content servers on an intranet to name applet 
servers on the same intranet. For example, a content server "content.example.com" 
could permit access to applets from all applet servers on the intranet (by placing 
"♦.example.com" in the allow list), except for applets from "www.example.com" 

25 (by placing "www.example.com" in the except list), which is considered less secure 
than the other applet servers on the intranet. Preferably, the intranet on which the 
systems and methods of the present invention is used is well configured and secure, 
since access to content servers is really only as secure as the rest of the network 
configuration. 

30 Use of Allow and Except constructs may be somewhat less secure if used on 

an extranet (such as the Internet), since, for example, it is not difficult for an applet 
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server to change its name to avoid the exclude list. Generally, the Allow-All 
construct should be used on extranets. It will be understood that these limitations for 
the use of the Allow, Exclude, and Allow-All constructs are merely guidelines, and 
that these constructs can generally be used with most any network configuration. 
5 In addition to being used to control access to content servers, the system and 

methods of the present invention maybe used to control the ability of applets to 
access the file system on a client computer. Name files, such as those described with 
reference to FIGS. 3 and 4 may be placed in directories on a client computer. Before 
an applet may access files in the directory that contains such a name file, the name 

10 file would have to be checked to see if the applets from the applet's home site are 
permitted to access files in the directory. This check would preferably be performed 
by file access restriction software in the execution engine that is executing the 
applet. Such file restriction software would preferably operate in a manner similar 
to the network restriction software described with reference to FIGS. 5 and 6. 

1 5 Use of a name file, as described herein, permits a trust decision about a 

resource to be specified at the resource to be accessed, while the enforcement of that 
trust decision is handled at the client that is running an applet that attempts to access 
the resource. Thus, in the case of a content server, the selection of which applets 
will be able to access the content server is specified on the content server, through 

20 the name file on the content server, while the enforcement of that decision is handled 
by the network restriction software of the execution engine on a client system. 
Similarly, when name files are used to control access to files systems, the decision 
about which applets will be permitted access is specified in the directory to be 
accessed, and the enforcement of that decision is handled by the execution engine. 

25 Since the name file is not present on the same system as the software that 

enforces the trust decisions in the name file, updating the client software requires 
special care. In a preferred embodiment, whenever an update is made that adds to 
the allowance syntax (e.g. Allow or Allow-AU), this is regarded as a minor version 
change in the name file syntax. Clients that encounter a name file that uses 

30 allowance syntax of a later version than they are able to handle may simply ignore 
any such allowance syntax that they do not understand. At worst, the syntax that is 
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being ignored may be intended to permit some applet to access resources, and the 
client that ignores that syntax will improperly deny such access. 

If there is a change in the denial syntax (Except), this is a major version 
change, and the client should not attempt to use the name file to grant or deny access 
5 to resources. This is because if a client misinterprets the denial syntax, an applet 
could be improperly granted access to resources to which access should have been 
denied. 

To create name files that are compatible with multiple versions of the client, 
a preferred embodiment of the present invention will place banners in the name file, 

1 0 identifying the version to which the following portion of the name file applies. A 
single name file can, using such banners, include complete trust instructions for 
several different versions of the client software that enforces those instructions. If a 
client encounters a banner that it knows how to handle, it will use the portion of the 
name file that follows that banner to grant or deny access to resources. 

1 5 Referring now to FIG. 7, an example of a computing environment in which 

the system and methods of the present invention may be used is described. 
Computers 80, 82, and 84, and server 86 are connected to one or more local area 
networks, such as local area network (LAN) 88. Each of computers 80, 82, and 84 
may execute a variety of software, all or part of which may be stored locally on 

20 computers 80, 82, or 84, or may be stored on server 86, and accessed over LAN 88. 

LAN 88 is connected to a wide area network (WAN) 89, such as the Internet, 
through gateway 87, which may be a dedicated device, or may be a computer or 
server, similar to computers 80, 82, and 84, or server 86. Additionally, gateway 87 
may provide the functions of a firewall, preventing unauthorized network 

25 connections from being established with computers on LAN 88 from computers 
outside of LAN 88. 

By sending communications across WAN 89, any of the devices connected to 
LAN 88 may communicate with remote servers 85 and 83, as well as other 
computers or devices that can be accessed over WAN 89. Computers 80, 82, and 84 
30 may gain access to information and software through WAN 89, including applets or 
other mobile code. Such applets may, for example, be stored on remote server 85, 
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and may be accessed by any of computers 80, 82, or 84, which may transfer the 
applet from remote server 85, so as to execute the applet locally. 

Each computer or device accessible through WAN 89 has a name, and a 
numerical address. Some of the computers or devices which may be accessed 

5 through WAN 89 have multiple names which refer to the same numerical address, or 
may have multiple numerical addresses and multiple names. The names of devices 
connected to WAN 89 can be translated into corresponding numerical addresses by a 
set of DNS servers (not shown) connected to WAN 89. 

It will be understood by one skilled in the art that the network configuration 

1 0 shown in FIG. 8 is for illustration only, and that most any network configuration 
maybe used with the system and methods of the present invention. Further, it will 
be understood that many types of devices may be connected to LAN 88, including 
printers (not shown), storage devices (not shown), and other types of devices that 
may be connected to a network. 

1 5 Referring now to FIG. 9, a block diagram of a computer system suitable for 

use with the present invention is described. Computer system 90 includes at least 
processor 92 for processing information according to programmed instructions, and 
memory 94, for storing information and instructions for processor 92. Additionally, 
computer system 90 may optionally include storage system 96, such as a magnetic or 

20 optical disk system, for storing instructions and information on a relatively long- 
term basis. Computer system 90 also may include network interface 97, and display 
system 99, such as a video controller and monitor, on which infoimation may be 
displayed. Processor 92, memory 94, storage system 96, netwoik interface 97, and 
display system 99 are coupled to bus 98, which preferably provides a high-speed 

25 means for devices connected to bus 98 to communicate with each other. 

It will be apparent to one of ordinary skill in the art that computer system 90 
is illustrative, and that alternative systems and architectures may be used with the 
present invention. It will further be understood that many other devices, such as an 
audio output device (not shown), and a variety of other input and output devices (not 

30 shown), such as keyboards and mice, may be included in computer system 90. 
Computer system 90 may be a personal computer system, a workstation, a set-top 
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box desigaed to be connected to a television or other similar display, a hand-held 
device, such as a cell phone or personal digital assistant, or any other device that 
contains a processor capable of executing programmed instructions and a memory 
capable of storing programmed instructions. 

5 Those skilled in the art should readily appreciate that the programs defining 

the operations and methods defined herein are deliverable to a computer in many 
fonns, including but not limited to a) information permanently stored on non- 
writeable storage media such as ROM devices, b) information alterably stored on 
writeable storage media such as floppy disks, magnetic tapes, CDs, RAM devices, 

10 and other magnetic and optical media, or c) information conveyed to a computer 
through communication media, for example using baseband signaling or broadband 
signaling techniques, as in an electronic network such as the Internet or telephone 
modem lines. The operations and methods may be implemented in a software 
executable out of a memory by a processor or as a set of instructions embedded in a 

1 5 carrier wave. Alternatively, the operations and methods may be embodied in whole 
or in part using hardware components, such as Application Specific Integrated 
Circuits (ASICs), state machines, controllers or other hardware components or 
devices, or a combination of hardware and software components. 

While preferred illustrative embodiments of the present invention are 

20 described above, it will be evident to one skilled in the art that many changes and 
modifications may be made without departing from the invention. 
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What is claimed is: 

1. A method of creating a network connection between an applet executing on a 
client computer and a content server computer, the method comprising: 
5 determining a home site name for the applet, the home site name 

corresponding to a host name of a computer from which the applet was 
downloaded to the client computer; 

checking for the presence of a hostname entry in a name file on the 
content server computer having an access construct, the hostname entry 
10 corresponding to the home site name for the applet; 

permitting the applet to create a network connection with the content 
server computer if the hostname entry was present; and 

denying permission for the applet to create a network connection with 
the content server computer if the hostname entry was not present. 

15 2. The method of claim 1 , wherein an execution engine executes the applet on 
the client computer, and wherein checking for the presence of a hostname 
entry in the name file of the content server computer comprises using 
network restriction software in the execution engine to check for the presence 
of the hostname entry. 

20 3. The method of claim 1, wherein the access construct comprises an allow list, 
the allow list comprising the hostname entry representing a computer from 
which the applet is allowed to have been download from in order to allow the 
creation of the network connection 



4. 

25 



The method of claim 3, wherein the host name entries are specified using 
wildcards. 
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5 . The method of claim 1 , wherein the access construct comprises an except 
list, the except list comprising the hostname entry representing a computer 
from which the applet is not allowed to have been downloaded from in order 
to allow the creation of the network connection. 

5 6. The method of claim 5, wherein the host name entries are specified using 
wildcards. 

7. The method of claim 1 , wherein the access construct comprises a special 
entry to allow access to applets downloaded for any host computer. 

8. The method of claim 1 , further comprising using the hostname entry to 

10 determine types of network connections that are permitted between the applet 

and the content server computer. 

9. The method of claim 1, further comprising performing an address check. 

10. The method of claim 9, wherein performing an address check comprises: 

determining an address list for the content server computer, 
1 5 determining an address list for the computer from which the applet 

was downloaded; and 

denying permission for the applet to create a network connection with 
the content server computer if the address list for the content server computer 
is not a subset of the address list for the computer from which the applet was 
20 downloaded. 

1 1 . The method of claim 9, wherein performing an address check comprises 
denying permission for the applet to create a network connection with the 
content server computer if the home site name for the applet is in dotted quad 
form, and an address specified by the dotted quad form is not identical to an 

25 address for the content server computer. 
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12. A computer program product comprising: 

a computer usable medium for creating a network connection 
between an applet executing on a client computer and a content server 
computer; 

5 a set of computer program instructions embodied on the computer 

usable medium, including instructions to: 

determine a home site name for the applet, the home site name 

corresponding to a host name of a computer from which the applet was 

downloaded to the client computer; 
10 check for the presence of a hostname entry in a name file on the 

content server computer having an access construct, the hostname entry 

corresponding to the home site name for the applet; 

permit the applet to create a network connection with the content 

server computer if the hostname entry was present; and 
1 5 deny permission for the applet to create a network connection with 

the content server computer if the hostname entry was not present 

13. A computer data signal embodied in a carrier wave comprising a code 
segment for creating a network connection between an applet executing on a 
client computer and a content server computer, the code segment including 

20 instructions to: 

determine a home site name for the applet, the home site name 
corresponding to a host name of a computer from which the applet was 
downloaded to the client computer, 

check for the presence of a hostname entry in a name file on the 
25 content server computer having an access construct, the hostname entry 

corresponding to the home site name for the applet; 

permit the applet to create a network connection with the content 
server computer if the hostname entry was present; and 

deny permission for the applet to create a network connection with 
30 the content server computer if the hostname entry was not present. 
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14. A computer system for creating a network connection comprising: 
a client computer executing an applet; 
a content server computer having a name file; 
a processor executing the applet on the client computer and 
5 determining a home site name for the applet, the home site name 

corresponding to a host name of a computer from which the applet was 
downloaded to the client computer, checking for the presence of a hostname 
entry in the name file on the content server computer having an access 
construct, the hostname entry corresponding to the home site name for the 
1 0 applet, permitting the applet to create a network connection with the content 

server computer if the hostname entry was present, and denying permission 
for the applet to create a network connection with the content server 
computer if the hostname entry was not present. 



15. A computer system for creating a network connection between an applet 
1 5 executing on a client computer and a content server computer, comprising:a means 
for determining a home site name for the applet, the home site name corresponding 
to a host name of a computer from which the applet was downloaded to the client 
computer, 

a means for checking for the presence of a hostname entry in a name 
20 file on the content server computer having an access construct, the hostname 

entry corresponding to the home site name for the applet; 

a means for permitting the applet to create a network connection with 
die content server computer if the hostname entry was present; and 

a means for denying permission for the applet to create a network 
25 connection with the content server computer if the hostname entry was not 

present. 
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